/*
 * Copyright 2025 Snowflake Inc.
 * SPDX-License-Identifier: Apache-2.0
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/*
 * User-defined functions for testing cancellations.
 */

#include "postgres.h"
#include "fmgr.h"

#include "pg_lake/pgduck/client.h"
#include "utils/builtins.h"


PG_FUNCTION_INFO_V1(execute_in_pgduck);


/*
 * execute_in_pgduck runs a query via pgduck.
 */
Datum
execute_in_pgduck(PG_FUNCTION_ARGS)
{
	char	   *queryString = text_to_cstring(PG_GETARG_TEXT_P(0));

	ExecuteCommandInPGDuck(queryString);

	PG_RETURN_VOID();
}
